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مقدمة الكتاب 


بسم الله والصلاة والسلام على رسول الله وآله وصحبه» وبعد: 

هذا الكتاب موجه إلى القارئ الشغوف» الذي لا يعرف ما هي فيجيوال بيزيك 
دوت نت» أو ما هي البرمجة عموماء ويريد أن يأخذ جولة سريعة مختصرة› 
ولكن في نفس الوقت وافية» وكافية لكي يقرر إن كانت البرمجة هي المجال 
الذي يناسبهء وفيجيوال بيزيك هي لغة البرمجة التي يستطيع الاعتماد عليهاء أم 
لا. 

وهو موجه أيضا إلى الطالب أو الدارس الذي يريد أن يلم في أسرع وقت 
بمهارات فيجيوال بيزيك الأساسيةء التي تؤهله لدراسة أحد المناهج» أو تساعده 
في إنجاز مشروع التخرج أو كتابة برنامج مساند لرسالته البحثية. 

وهو موجه كذلك إلى الموظف أو المحاسب» الذي سمع عن قدرة فيجيوال 
بيزيك على تطوير تطبيقات تجارية قوية» فانتابه الفضول للتعرف على هذه 
اللغةء وشعر بالرغبة في تجربتها بنفسه»ء لإنشاء برنامج سريع ينظم به عمله» 
ويطبق فيه كل الأفكار التي لم تستطع البرامج الجاهزة تقديمها له.. هذا الكتاب 
يعطيه مثالا جيدا لمشروع يعمله كيفيه إنشاء قواعد البيانات واستخدامها في 
حفظ البيانات والبحث فيها وعرضها بأشكال مختلفة. 


وهو موجه بوجه عام للمبتدئين في البرمجةء الذين يريدون مشاريع كبيرة 
مشروحة بالكامل» يستطيعون الاستفادة بأجزاء منها أثناء برمجتهم للمشاريع 
المطلوبة منهم. 

ا کا ی کن ا هلو ا هن ر اة ااا و الها 
والأمثلة الصغيرة» ويريدون أن يتعلموا كيف يطورون مشروعا عملياء ي ربط 
الأجزاء التي تعلموها بعضها ببعض» ويمنحهم الكثير من الخبرات العملية. 


لكي يحقق هذا الكتاب كل هذه الأهداف» تم تصميمه ليقفز بقارئه مباشرة إلى 
منتصف ورشة العمل» أثناء تطوير مشروع متكامل اسمه المذكرة الذكيةء بدون 
أي مقدمات أو شروح نظرية لأساسيات البرمجة أو لغة فيجيوال بيزيك» فبدلا 
من هذاء يريك الكتاب خطوات العمل على الهواء مباشرةء وكلما تطلب الأُمر 
شرح جزء من لغة فيجيوال بيزيك» يتم شرحه باختصار واف» وعلى قدر 
الحاجة. 

ويقدم الكتاب تصميمين مختلفين للمذكرة الذكيةء أحدهما برنامج شخصي 
لمستخدم واحد يحفظ البيانات في ملف على الجهاز» والآخر برنامج متعدد 
المستخدمين» يتيح لأكثر من مستخدم التعامل معه في نفس الوقت» من خلال 
قواعد بیانات "سیکویل سیرفر " SQ Seve‏ . 

وهكذاء وبنهاية هذا الكتاب» يكون القارئ قد أخذ نظرة واسعة على فيجوال 
بيزيك» وتعلم ما يلي : 


- أساسيات لغة البرمجةء كتعريف المتغيرات» وحلقات التكرار ك00pء‏ 
وجمل الشرطء واستخدام المجموعات ك«هن)ءم[اه€» وتعريف الدوال 
Functions‏ و السجلات Structures‏ والفثات sعC1ass.‏ 

- برمجة نماذج الويندوز» وتصميم النماذج وواجهة الوثائق المتعددة 
واستخدام الأدوات الأساسيةء كالأزرار ومربعات النصوص ومربعات 
القوائم ×0 is8‏ وأزرار التحویل tt0 1S‏ 08u¡لهR‏ ومربعات 
الاختيار sء×80)ءeءnط€.‏ واللوحة اعمص۴a‏ ومربع التجميع »GroupB0X‏ 
وأداة مزود الخطاً ErrorPr ov ¡der‏ وأداة تلميحات الشاشة 1pآ01٥1»‏ 
والقوائم الرئيسية كuامءM.‏ 

- إنشاء أداة خاصة اهاوه t0mءu٤»‏ لعرض المواعيد بصورة مرئية 
واضحة وسهلةء واستخدامها في تصميم المذكرة الذكية. 

- إجادة الكثير من المواضيع المتقدمة»ء كالنقل المتسلسل للبيانات 
Serlal1ati10n‏ وكتابة استعلامات 110[ وبرمجة قواعد بيانات .ا9 
Serve‏ من خلال النموذج التصوري 1عءلM0‏ |a1»اامعءءمهC‏ الذي تقدمه 
لنا تقنية ا@S‏ 10 111,0 وربط البيانات ع«iلم¡8 0ata‏ وعرضها 
في الأدوات المتقدمة مثل جدول الععرض ء046۲4۷1 وإنشاء 
أعمدة من أنواع خlاصة «Custom DataGridView Columns‏ 
لعرض البيانات في جدول العرض بالشكل الذي يناسبنا. 

وغير ذلك الكثير ! 


أعرف أنك مندهش» و أنك ستقلب الكتاب بين يديك وتقول غير مصدق : 

- كيف يمكن لكتاب صغير الحجم بهذا الشكل» أن يقدم مشروعين كبيرين 

ويشرحهما خطوة بخطوة» ويتناول في نفس الوقت كل هذه المواضيع؟! 

ولكنها الحقيقية يا صديقي بدون أي مبالغةء فبين يديك كتاب غير تقليدي» 
ستستمتع بكل جملة تقرؤها فيهء لأنه مصمم أساسا ليجعلك تعرف لماذا يعشق 
الآخرون البرمجة. 
دعنا لا نضيع المزيد الوقت في مقدمات» فلدينا مشروعان شيقان يناديان أن 
هلموا! 


متطلبات أساسية في قارئ الكتاب: 
لا يشترط هذا الكتاب في قارئه أي معرفة مسبقة بلغة فيجيوال بيزيك» ولا بأي 
لغة برمجة على الإطلاق. 
وليس شرطا أن يكون طالبا في كلية الهندسة أو الحاسبات والمعلومات.. 
فالمشروعان الموجودان في هذا الكتاب لا يتطلبان أي خلفية معرفية في 
الرياضيات أو المحاسبة أو أي علم متخصص.. بل يمكن حتى لطالب المرحلة 
الثانوية قراءته وتنفيذ ما فيه بدون أي تعقيد. 
كل المطلوب من قارئ هذا الكتاب» هو ما يلي: 
- أن يجيد أساسيات التعامل مع الحاسوب ونظام تشغيل الويندوز . 
- أن يعرف الحد الأدنى من اللغة الإنجليزيةء لأن أوامر لغة البرمجة تكتب 
بها.. وهي إنجليزية بسيطةء لا تزيد عن مستوى طالب الصف الثالث 
الإعدادي» فلغة البرمجة لا تهتم بقواعد النحو والصرف» وقاموس الكلمات 


المستخدم فيها محدود للغايةء ويكفي أن يمتلك المرء القدرة على قراءة 

الكلمات الإنجليزية لكي يألفها بسرعة.. وعموماء أنا أترجم في هذا الكتاب 

كل مصطلح برمجي وكل أمر من أوامر اللغة» حيث أكتب الكلمة العربية 

بجوار الكلمة الإنجليزية. 

- أن يعد لغة البرمجة على جهازه» وقد شرحنا خطوات الإعداد بالتفصيل 

في بداية هذا الكتاب. 
وعلي هنا أن أقدم نصيحة للقارئ حتى يخرج بأقصى استفادة ممكنة من الكتاب 
باذن الله: 
يجب أن تنفذ كل حرف نشرحه في هذا الكتاب بيدك عمليا.. فهذا الكتاب ليس 
للتسلية في الحافلة أو القطارء ولا يمكنك قراءته وأنت مضطجع في فراشك.. 
يجب أن تكون بجوار الحاسوب وأنت تقرأً هذا الكتاب» وأن تتفذ كل خطوة في 
المشروع بعد أن تفهم شرحها جيداء لأنك لو فقدت تسلسل الفهم» أو اعتمدت 
على قراءة الكتاب كأنه جريدة ونسيت في منتصفه ما قرأته في أوله» بسبب عدم 
ممارستك له عمليا وعدم كتابة الكود بيدك» فستجد نفسك عاجزا عن المواصلة 
أو الاستفادة. 
ولا يهم أن تنتهي من قراءة الكتاب بسرعةء بل المهم ألا تنتقل من فقرة إلى 
أخرى إلا بعد فهمها فهما جيداء وتطبقها بنفسك في فيجيوال بيزيك» فتعلم 
البرمجة أشبه بصعود سلم» كل درجة فيه تفضي إلى الدرجة التالية لهاء ولو 
فقدت بضع درجات فستسقط سريعا ولن ترقى إلى مبتغاك. 
وأنصحك أخيرا بأن تخصص وقتا للكتاب يوميا حتى لو كان صغيراء فهجر 
الكتاب لفترة طويلة قد يجعلك تتسى ما سبق أن تعلمته من أساسيات البرمجة»ء 


كما أنك قد تنسى أسماء النماذج ووظائفها والمنطق العام الذي نتبعه في 
المشروع» مما يصعب عليك متابعته دون مراجعة ما سبق. 

هذه فقط هي كل المؤهلات المطلوبة منك» وكما ترى» فهي مؤهلات يسهل 
توفرها في كل من يحب ما يتعلمه ولديه الحماس الكافي والصبر على 
المواصلة. 


والله ولي التوفيق 


اسلة الكاتب و التو اصل معه: 


msvbnet @ hotmail.com 
مدونة م. محمد حمدي غانم:‎ - 


http://mhmdhmdy.blogspot.com 


مشروع المذكرة الذكية 
باستخدام قواعد البيانات 


قاعدة البيانات :Database‏ 
هي ملف أو مجموعة من الملفاتء تستخدم لتخزين البيانات.. وتتميز 
قاعدة البيانات عن الملفات العاديةء بوجود برامج خاصة للتعامل معهاء 
مما يجعل حفظ البيانات وقراءتها والبحث فيها أُمورا أكثر سهولة 
وتنظيمًاء وخالية من الأخطاء.. هذه البرامج تسمَّى "أنظمة إدارة قواعد 
البيانات": 
Database Management Systems (DBMS)‏ 
وتحتوي قاعدة البيانات على أنواع مختلفة من العناصرء منها الجداول 
6 والعلاقات ١١٥1اهآم 8R‏ .. حيث توضع البيانات في الجداول» 
التي يمكن أن ترتبط بعلاقات فيما بينها.. ويتكون كل جدول من: 
أغمدة اعا لکل منها اسم محدد ونوع بیانات محدد.. 
ويكون عدد أعمدة الجدول ثابتا.. ويطلق على العمود ١دصuاه٣‏ 
أيضا اسم الحقل 4[ع ۴ . 
- وصفوف ء80۷ توضع فيها البيانات .. ويمكنك إضافة مئات أو 
آلاف أو ملايين الصفوف إلى الجدول على حسب الحاجة.. 
ويطلق على الصف 8۸0 أيضا اسم السجل R0۲4‏ . 


سیکویل سیرفر ۲۰۰۸: 
هناك أنواع كثيرة من قواعد البيانات» مثل قواعد بيانات ءءء وقواعد 
بیانات 5Q1 S٥۷٥۲‏ وهما من إنتاج ميكروسوفت.. وسنستخدم هنا قواعد 
بیانات S۲۷۵۲‏ 5891 لأن فیجيوال بيزيك دوت نت تقدم لھا دعما كاملا 
يجعل التعامل معها أسهل وأسرع» كما أن سيكويل سيرفر يتيح لنا تشغيل قاعدة 
البيانات على خادم 5٥۲۷٥١‏ مما يجعل كل مستخدمي البرنامج يشتركون في 
التعامل مع نفس قاعدة البيانات. 
ويجب أن يكون سيكويل سيرفر معدا على جهازك لكي يمكننا التعامل مع قواعد 
البيانات الخاصة به.. وإذا لم يكن هذا البرنامج لديك» فيمكنك استخدام نسخة 
خفيفة منه اسمها: 
SQL Server 2008 Management Studio Express‏ 
أو ما يمكن أن نسميه بالعربية مدير سيكويل سيرفر ..۲٠٠۸‏ ويمكنك الحصول 
عليه مجانا من صفحة تنزيل البرامج من موقع ميكروسوفت: 
http://www.microsoft.com/downloads‏ 
في أعلى هذه الصفحة ستجد مربع البحث.. اكتب فيه النص: 
SQL Server 2008 Management Studio‏ 
واضغط زر البحث (الذي تمثله أيقونة العدسة أللا).. ستجد في نتائج البحث 
رابط البرنامج الذي تبحث عنه.. اضغطه لعرض صفحة تنزيله» واضغط زر 
تنزيل النسخة المناسبة لنظام التشغيل الموجود على جهازك. 


عد :Management Studio Express‏ 
قبل أن تبدأً إعداد هذا البرنامج على جهازك» علي أن أنبهك إلى ضرورة التأكد 
من أنك قد اخترت إعداد العنصر: 
Microsoft SQL Server 2008 Express Edition‏ 

أثناء إعداد فيجيوال ستديو دوت نت ٠٠٠٠١‏ وإلا فإن عليك إعادة تشغيل ملف 
إعداد دوت نت» واختيار Add or Remove Features‏ ومن ٹم وضع 
علامة الاختيار أمام هذا العنصرء حتى تستطيع فيجوال ستديو التعامل مع 
سیکویل سیرفر ۲۰۰۸. 
والاآن» اضغط برنامج الإعداد الخاص ب: 

SQL Server 2008 Management Studio Express 
وانتظر حتى تظهر الشاشة الموضحة في الصورة:؛‎ 
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من الهامش الأيسر» اضغط الاختيار الثاني 211٤ء[‏ حيث سيعرض لك الجزء 
الأيمن من النافذة عدة اختيارات.. إذا لم تكن قد أعددت إصدارا سابقا من 
سيكويل سيرفر على جهازك» فاضغط الاختيار الأول.. سيتم أولا التأكد من 
وجود المتطلبات اللازمة للاإعداد على جهازك» فإن كانت كلهاموجودة 
فاضغط 0 وواصل باقي خيارات الإعداد.. وتأكد دائما من ضغط الزر 
1ل 1ءعاعS‏ في كل صفحة تعرض العناصر المتاحة للإعداد» لتضمن إعداد 
كافة مكونات البرنامج. 


ملحوظة: 
قد يحدث خطأ في برنامج الإعدادء حيث ستخبرك الرسالة أنها تحتاج 
واحدا أو أكثر من البرامج التالية: 
Windows Installer 4.5‏ 
WS-Management v1.1‏ 


Windows PowerShell V2 (CTP3) 
.NET Framework 3.5 SP1 


ويمكنك الحصول على أي برنامج منها بالبحث عن اسمه في صفحة 
تنزيل البرامج من موقع ميكروسوفت كما شرحنا أعلاه» وإعداده على 
جهازك إذا تطلب الأمر ذلك . 


تصميم قاعدة البيانات: 
ابد مشروعا جديدا اسمه 00)58 »Smar٤N eb‏ واحفظه في الموضع 
ا ع 


الآنء وقبل أن نصمم نماذج هذا المشروع» علينا أن نصمم قاعدة البيانات أولا.. 
دائما ما تكون هذه هي أول خطوة في مشاريع قواعد البيانات. 

لفعل هذاء افتح القائمة الرئيسية اععزهإ۴ واضغط الأمهر «Add New Item‏ 
وفي نافذة إضافة عنصر اختر النوع مء2طه)a(‏ من القائمة اليسرى» واختر 
العنصر كعءءها€ 1١ SQ]‏ 11,0 من القائمة اليمنى.. اكتب في خانة الاسم 
SmariNNoteBookDB‏ واضغط زر الموافقة.. سيؤدي هذا إلى إضافة عنصر 
جديد إلى متصفح المشاريع اسمه ›»SmartNoteBookDB.db m1‏ وسیتم 
عرض محتوياته في نافذة تسمى مصمم الكائنات.. هذا العنصر يسمى محتوى 
البيانات ٤×٥٤07٤هاه‏ ونظرا لأنه ما زال فارغاء فستظهر النافذة فارغة. 

لو فتحت صندوق الأدوات الآنء فستجد فيه أدوات جديدة غير التي نستخدمها 


في تصميم النماذج.. هذه الأدوات تستخدم لتصميم عناصر محتوى البيانات. 


محتو ى البياناٽ :Data Context‏ 

يسمى أيضا بالنموذج التصوري 1ءلM0‏ اuaامعءnهC»‏ وهو طبقة 
قصل با ونين قاغدة الشانات؛ رفا تت اء مخيرغة من :الشات 
لتمثل كل منها نوع صفوف أحد الجداول.. وتحتوي كل فة على 
خصائص تمثل كل خاصية منها أحد أعمدة الجدول.. كما يمكن إنشاء 
ارتباط بين فئتين ليمثل العلاقة بينهما.. إذن: 

الفئة ئها ---> صف 8٠W‏ في أحد الجداول 
الخاصية رااممهإ۴ ---> عمود ١ص‏ اه٤‏ في هذا الجدل 


الارتباط 0n‏ iاھ¡ءمsءA‏ - - > علاقة «10اهامR‏ بين جدولين 


۱۲ 


من صندوق الأدوات اسحب العنصر كءه1٤‏ وأسقطه على مصمم الكائنات.. 
سيؤدي هذا إلى إضافة فئة جديدة إلى المصمم؛ . 
وسيكون اسمها الافتراضي 11ا٣‏ كما تبدو في 1 
الصورة المجاورة. 

ولتغيير اسم الفئة انقره مرتين بالفأرة.. سيؤدي هذا | 
إلى عرض الاسم في مربع نص حتى يمكنك تغییره.. اکتب الاسم ۸4ع۴1 
واضغط ۲ع ٤۸)‏ . 

ولإضافة خاصية إلى الفئة» اضغطها بزر الفأرة الأيمن» ومن القائمة الموضعية 
اضغط 4ل ومن القائمة الفرعية اضغط الأمر ,اعم ه۴.. سيظهر عنوان 
جديد داخل المستطيل الممتل ألفةة اسمهة  .‏ 


a 
اھ‎ | 


Classl 


= Properties 


Friend 
8م وتحته ستظهر خاصية جديدة»‎ 
= Proğêrtiês ا‎ 
a ولتغییر‎ ..۴۲٥ص‎ ٥۲۲۷1 وسیکون اسمها الافتراضي‎ 
" Name 2 ^ EF oR ًه‎ 
2 Address هذا الاسم انقره مرتين بالفارةء واكتب الاسم 10 ثم‎ 
E . 8)٥٣ اضغط‎ 
î LOMpANY 
لاحظ أنك لو ضغطت ۲٥ا۴ مرة أخرى ا‎ 
1 NOLES 


فستضاف خاصية جديدة في وضع التحرير 


مباشرة.. هذا تسهيل يجعل إضافة الخصائص أسرع» حيث تكتب الاسم وتضغط 
En‏ مرتین وتکتب الاسم التالي وتضغط ۴1)٥۲‏ مرتين.. وهكذا, 


كما أنك تستطيع تغيير اسم الخاصية بضغطها مرة بالفأرة لتحديدهاء والكتابة من 
لوحة المفاتيح مباشرةء حيث سيؤدي هذا إلى الانتقال إلى وضع التحرير.. 
استخدم هذه الطريقة لإضافة الخصائص التالية إلى الفئة ۴:٥۸۵‏ : 

.Notes «Job «(Company «<BirthDate «Address «Name «ID 
كما في الصورة.‎ ۴۲1٥٠١١ يجب أن يبدو مخطط الفئة‎ 

لاحظ أن كل الخصائص التي أضفتها تم جعلها من النوع S1١‏ تلقائيامع 
کا خف اتی فر ا ھک غ کد خککن کل کا کے جد 
لفعل هذاء حدد الخاصية في مخطط الفئة بضغطها مرة واحدةء ثم اضغط ۴4 
E E E OE PO OE TES‏ 


بالنسبة للعمود 10: 

هذا العمود سيعمل كمفتاح أساسي اء رإه "إ۴ لجدول الأصدقاء.. المفقاح 
الأساسي هو عمود يحتوي على قيمة متفردة لكل صف في الجدول.. وفي 
الغالب يحتوي هذا العمود على أرقام يتم توليدها آلياء بحيث يأخذ كل صف 
رقما خاصا به.. فنقول مثلا إن أحمد رقمه ٠‏ في جدول الأصدقاء» ومحمود 
رک 

ولجعل العمود 12 مفتاحا أساسياء يجب أن تضبط قيم خصائصه كماهو 
موضح في الجدول التالي: 


0 


الخاصيه 
مفتاح أساسي 
Primary Key‏ 
قيمة مولدة تلقائيا 
Auto‏ 


Generated 
Value 


للقر أءة فقط 
Read Only‏ 


تزامن تلقائي 
Auto-Sync‏ 


True 


عند الإضافة 
OnlInsert‏ 


ملاحظات 
سيظهر رمز المفتاح بجوار العمود 
في مخطط الفئة ۲0۸ء۴ , 
هذه الخاصية تطلب من قاعدة 
البيانات توليد قيم المفتاح الأساسي 
تلقائيا. 
سيكون المفتاح الأساسي للقراءة 
فقط» حتی لا نسمح بتغيير قيمته 
بعد تولیده. 
ستولد قاعدة البيانات المفقاح 
الأساسي عندما يتم حفظ سجل 
جديد في قاعدة البيانات» بينما لن 
نستطيع نحن تغيير قيمته لأننا 
جعلناه للقراءة فقط.. لهذا يجب أن 
نطلب من قاعدة البيانات أن ترسل 
إلينا قيمة المفتاح الأساسي الذي 
قامت بتوليده» لتوضع في الخاصية 
تلقائياء وبذلك يكون برنامجنا 
متزامنا مع قاعدة البيانات. 


لاحظ أن أي مفتاح أساسي تنشئه» يجب أن تضبط خصائصه كما في الجدول 
السابق. 

بقي أن نصحح نوع البيانات التي ستوضع في العمود 10.. لو نظرت إلى 
الخاصية مم1 فستجد آنها من النوع ګ٣1)؟..‏ غیرها إلى إ٥ع٥اہ!‏ ليكون 
المفتاح الأساسي عددا صحيحا. 


بالنسبة للعمود عصNa:‏ 
لن نغير شيئًا في خصائصه»ء لأنه بالفعل يتعامل مع نصوص عادية. 


yبlلنسqة‏ lاعnدة :Notes «Job «(Company «Address‏ 
فهي أيضا أعمدة نصيةء ولكننا سنغير فيها شيئًا واحدا.. فنحن نريد أن نسمح 
لهذه الأعمدة بأن تكون فارغةء فربما لا يعرف المستخدم الشركة التي يعمل فيها 

صديقه» أو لا توجد لديه ملحوظات.. إلخ. 

تتحكم في هذا خاصية القابلية للانعدام 1#طة ا١ء‏ وتكون القيمة الافتراضية لها 
6 لكي لا يتم ترك أي خانة في العمود فارغة.. غير هذه القيمة إلى عںإ1 
في كل من lاÎJأعnدةö .Notes «Job «Company «Address‏ 


وأخيرا بالنسبة للعمود Birth Date‏ : 

استخدم الخاصية ١ءمرآ‏ لتغيير نوع هذا العمود إلى ع)54.. وسنسمح أيضا 
بترك هذا العمود فارغاء لهذا ضع ع1۲ في الخاصية عاطNulla.‏ 

ل نتس ضغط ؟+1])٥‏ لحفظ عملك بين فترة وأخرى. 


ربط محتوى البيانات بقاعدة البيانات: 
تتبقى خاصية هامةء يجب أن نضع قيمتهاء وهي خاصية المصدر eءإاهS؟ء‏ 
وهي تعني العنصر الأصلي في قاعدة البيانات» الذي سيرتبط به العنصر 
الموجود في محتوى البيانات.. دعنا نتفق على هذين المبدأين: 
- كل فئة في محتوى البيانات» سيكون مصدرها جدول اسمه هو لفظ الجمع 
لاسم الفئة.. على سبيل المثال: الفثة ۴۴۲01۸ سيكون مصدرها جدول 
الأشخاص ك١0ءإ۴..‏ السبب في هذا أن الفشة ۶0۸ تمشل صفا 
واحدا في الجدول ك«صمءإم۴.. لفعل هذا حدد مخطط الفشة ۹0۸إم۴ 
بضغط أي جزء منها خار ج جز ء الخصائص» واضغط ۴4 لعرض نافذة 
الخصائص» واكتب في الخاصية ع٥501۲‏ الكلمة كsو0یإم۴.‏ 
- كل خاصية في الفئة» سيكون مصدرها العمود الذي يحمل نفس اسمها 
في الجدول.. لاحظ أن من الممكن أن نجعل كلا الاسمين مختلفين دون 
أن يوثر هذا على عمل البرنامج.. لكننا حاليا سنجعل للخصائص نفس 
أسماء الأعمدة.. حدد كل خاصية في الفئة ۴٠۲١0١‏ وضع في الخاصية 
ure‏ التابعة لها نفس اسمها. 


فئة الهھاتف :Ph0n¢‏ 

بنفس الطريقة السابقةء أضف فئة جديدة إلى محتوى البيانات» واجعل اسمها 
مص0ط۴» واستخدم الخاصية ١٠ا50‏ لربطها بالجدول sع«0ط٣۲‏ في قاعدة 
البيانات.. هذا الجدول وظيفته أن نضع فيه كل أرقام هواتف الأشخاص»ء حيث 


سنربط رقم الهاتف بصاحبه من خلال عمود اسمه (۲۵۲۹0۸1۲»› سنضع فيه رقم 
الشخص.. يسمى هذا العمود بالمفتاح الثانوي أو المفتاح الغریب ۴٥۲٤1۸‏ 
رع لأنه يحمل قيمة المفتاح الأساسي لجدول آخر . 

ولكن: لماذا لم نضع ثلاثة أعمدة في جدول الأشخاص لتحمل هاتف المنزل 
ر الل و المك رل اذا نانا كدر لا خاضا هدا الم 

في الحقيقةء هناك ميزتان في هذا: 

١‏ - إذا لم يكن للشخص أي هواتف» فلن نترك ثلاث خانات في جدول 
الأشخاص فارغة.. بل كل ما سنفعله» هو ألا نضيف أي سجل خاص به 
في جدول الهواتف. 

١‏ - إذا كان للشخص هاتف واحد فسنضيف سجلا له في جدول الهواتف.. 
وإذا كان له أربعة هواتف فسنضيف أربعة سجلات في جدول الهواتف.. 
وإذا كان له عشرة هواتف فسنضيف عشرة سجلات!.. إذن فليست هناك 
أي حدود مفروضة علينا هناء وهذا مناسب لعمل الشركات» حيث يمكن 
أن يكون للشخص أكثر من هاتف في الشركة»ء ويحمل أكثر من شريحة 
محمول» ومتزوج بأكثر من امرآة وبالتالي له أكثر من هاتف منزلي [. 

والآن دعنا نضيف الخصائص اللازمة إلى الفئة ٥7٥ط۴..‏ مبہدئیاء يجب أن 
نتفق على أن كل فئة يجب أن تحتوي على مفتاح أساسي.. وحتى تسهل على 
نفسك» اضغط الخاصية 12 في الفئة ١0ء٠۴‏ بزر الفأرة الأيمنء ومن القائمة 
الموضعية اختر الأمر رإمه).. ثم اضغط الفئة ۴1٠,٠‏ بزر الفأرة الأيمن»› 
ومن القائمة الموضعية اختر الأمر عائه۴.. سيؤدي هذا إلى لصق الحقل 10 
وإضافته إلى الفئة ۴1006 بنفس اسمه وبكل خصائصه! 


والجدول التالي يصف لك الخصائص الأخرى التي يجب أن تضيفها إلى الففغة 


:Phone 
Nullable Type Source الخاصية‎ 
False Integer | PersonlD | PersonlD 
False String Phone Phone 
True String | Description | Description 


لاحظ أن خانة رقم الصديق وخانة رقم الهاتف لا يمكن تركهما فارغتين» وإلا 
فلن يكون هناك معنى للسجل الذي توجدان فيه.. أما خانة الوصف فيمكن تركها 
فارغة» أو يمكن أن يكتب فيها المستخدم ملحوظة تخص رقم الهاتف» مثل هل 
هو هاتف منزل أم عمل أم هاتف أحد الأقارب أو الجيران... إلخ. 
نريد الآن إنشاء علاقة بين جدول الأشخاص وجدول الهواتف.. يمكن فعل هذا 
في محتوى البيانات» بإنشاء ارتباط بين الفئة ۴٥۲0١‏ والفشغة ع٥١٥0ط۴..‏ اتی 
الخطوات التالية: 

١‏ - اضغط العنصر ١٥10اةءمووA‏ في صندوق الأدوات مرة واحدة بزر 

الفأرة وارفع إصبعك عن زر الفأرة. 

۲ - اضغط مخطط الفنة ۴٠۲١0١‏ مرة واحدة بالفأرة. 

۳ - اضغط الفئة ۴1٣٠‏ مرة واحدة بالفأرة. 
سيؤدي هذا إلى ظهور نافذة محرر الارتباطء وهي تبدو كما في الصورة: 


Parent Class: Child lass: 


| ا 
4 


أعلى النافذة تظهر قائمتان منسدلتان: 
- الأولى عنوانها "الفئة الأم" sئها٣‏ ا,رمإه۴.. الفئة الأم هي الفئة الرئيسية 
في الارتباطء وهي تحتوي على المفتاح الأساسي.. وهنا تم اختيار الفئة 
1 وتعطيل القائمة لكي لا تغير هذا الاختيار . 
- والقائمة الثانية عنوانها "الفئة الابنة" sوها€‏ 14نط٣..‏ الفئة الابنة هي 
الفئة الثانوية في الارتباط» وهي تحتوي على المفتاح الفرعي.. وهنا تم 
اختيار الفئة ۴1٥١١‏ وتعطيل القائمة لكي لا تغير هذا الاختيار . 
في النصف السفلي من النافذة» يظهر جدول يتكون من عمودين : 
- الأول عنو انه "خصائص الشخص'" ٤ع e۲٤‏ م٥۴‏ 0nءام۴»‏ ویجب أن 
تضيف في هذا العمود الخاصية أو الخصائص التي تعمل كمفتاح أساسي 
في الارتباط.. وعند الضغط في أي خانة في هذا العمود تظهر قائمة 
منسدلة فيها خصائص الفئة ٥۲50١‏ .. اختر منها الخاصية (10. 


- والثاني عنو انه "خصائص الهماتف" ۲۴٥p]:‏ 0neط٥۴»‏ ویجب أن 

تضيف في هذا العمود الخاصية أو الخصائص التي تعمل كمفتاح فرعي 

في الارتباط.. وعند الضغط في أي خانة في هذا العمود تظهر قائمة 
منسدلة فیھا خصائص الفئة ٥٣٥ط۴,,‏ اختر منھا الخاصیية (1ہہءrء۴P‏ . 

بهذا نكون ضبطنا الارتباط ليكون ..Phone.PersonID ڪy Perso1.1D jı‏ 
اضغط 0 لإنشاء هذا الارتباط.. لاحظ أن خطأً سيحدث وتفشل العمليةء لو لم 


يكن لكل من المفتاحين الأساسي والفرعي نفس نوع البيانات (وهو هنا 


. (Integer 
و ع٣٥٣۴ لیدل على‎ ٥٥۲۹0۸ بعد إغلاق النافذة› ستری سھما یصل بین الفئتین‎ 
الار تباط بينهما.‎ 
| Person ۾‎ 
Fhonê 2 
3 Properties 
3 د‎ 1 = Properties 
Ff Name ا‎ FF Ip 
ا‎ Addrêsš ت‎ ™T PersonID 
î BirtDate @ Phone 
™ Company ™ Description 
#7 ن ط30‎ 
TF Nokes 


وحينما تضغط هذا السهم بالفأرة سترى نقاطا عليهء يمكنك سحبه منها لتغيير 
تكله ومو عة كما ترذ وتمكتكف. ايضا أن تتغطهة يزر الفارة اللهن ون 


۲١ 


القائمة الموضعية تضغط الأمر 0c1101یی۸ ۴d1‏ لإعادة عرض نافذة 
تحرير الارتباط وتغيير اختياراتك. 
لاحظ أن إنشاء الارتباط سيضيف خاصيتين إلى الفئتين : 
- خاصية اسمها كعم«صمط۴ ستضاف إلى الفغة ١۲50ء۲»‏ وهي تعيد 
مجموعة تحتوي على جميع هواتف الشخص الحالي.. أي أن كل عنصر 
من عناصرها من النوع ٥١0ط۴..‏ مثلا: إذا كانت النسخة الحالية من 
الفثة ۴٠۲١0١‏ تشير إلى شخص اسمه "أحمد" ورقمه ١‏ في الجدول» فإن 
الخاصية ۲1٣٠١‏ ستحتوي على جميع هواتف "أحمد"» أو بمعنى آخر: 
ستحتوي على جميع الصفوف التي يوجد في الخانة 10١50ء۴‏ التابعة 
لها القيمة .١‏ 
- وخاصية اسمها ۴٠۲١0١‏ ستضاف إلى الفئة »۴10٥0٠‏ وهي تعيد نسخة 
من الفئة ۴٠۲0٥١‏ تشير إلى الشخص الذي ينتمي إليه الهاتف الحالي. 
لاحظ أن هاتين الخاصيتين لا تظهران على مخطط الفثتين» لكننا نستطيع 
استخدامهما من الكود. 


فئû‏ اء :Meeting Class‏ 
أضف فئة جديدة إلى محتوى البيانات اسمها 12ا16 واجعل مصدرها في 
قاعدة البيانات الجدول كع” اء (باستخدام الخاصية ١١إuاه؟)..‏ هذا الجدول 
ر و ا 

من خلال عمود المفتاح التانوي 0۸1۲0ء۴ , 


۲ 


إذن مبدئياء انسخ الحقلين 10 و 10ممءإم۴ من الفئة ۴10٣٠‏ والصقهما في 


.Meeting ةأفll‎ 
والجدول التالي يصف لك الخصائص الأخرى التي يجب أن تضيفها إلى الففة‎ 
:Meeting 
Nullable Type Source الخاصية‎ 
False Date Time Time 
False Date Duration Duration 
True String Place Place 
True String Reason Reason 
True String Notes Notes 
False Byte | ImportancelD | ImportancelD 


لاحظ أننا سنحفظ مدة اللقاء باعتبارها تاريخا.. هذا سيحل لنا العديد من المشاكل 
عند كتابة الاستعلامات على هذا الجدول كما سنرى لاحقا.. عموما كل ما يهمنا 
من هذا التاريخ هو جزء الساعات وجزء الدقائق فقط لأنهما يمثلان مدة اللقاءء 
أما باقي الأجزاء فسنهملها. 

بعد هذا أنشئ ارتباطا بین ۲0۸.10ء۴ و Meeting.Person10‏ بالطريقة 
التي تعلمناها. 


فئ الم :Importance Class‏ 
سيكون من المفيد أيضا أن نعرف فئة نضع فيها وصف أهمية الموعد التي 
تناظر الرقم الدال على هذه الأهمية.. هذا يتيح بعد هذا إضافة درجات أخرى 


۳ 


من الأهميةء كما أنه سيكون مفيدا لنا في عرض البيانات في جدول الععرض 
DataGridView‏ کما سنری لاحقا. 

أضف فئة جديدة إلى محتوى البيانات» واجعل اسمها عcمه)اممص]ء‏ واجعل 
مصدرها في قاعدة البيانات الجدول كعءمه)۲مم"] (باستخدام الخاصية 
(Source‏ . 

أضف إلى هذه الفئة مفتاحا أساسيا اسمه 15 وخاصية «Description lal‏ 
واجعل خصائصهما كما هو موضح في الجدول: 


Auto 
Generated Nullable Type | Source الخاصية‎ 
Value 
False False Byte ID ID 
False False String | Description Description 


أنشخ ارتباطا بين هذه الففغة والفشة عد نامه" بين الخاصيتين 
.Meeting.ImportancelID gs Importance.ID‏ 


فة المستخدم sئھا€ :User‏ 

أضف فئة جديدة إلى محتوى البيانات» اسمها ۲ءء واجعل مصدرها في قاعدة 
البيانات الجدول ءإءءآ (باستخدام الخاصية ..)50٠ ۲٥١١‏ سنضع في هذا الجدول 
تفاصيل مستخدمي البرنامج من موظفي الشركة.. ونظرا لأن المستخدم هو في 
الحقيقة شخص» فسنضع بياناته في الجدول ك«مءإه۴» ونربط بينه وبين جدول 
المستخدمين عن طريق المفتاح الفرعي (0۸1ءإء۴ . 


٤ 


إذن مبدئياء انسخ الحقلين 10 و (10مهمءإم۴ من الفئة ۴107٠‏ والصقهما في 
الفئة إمء ل , 

لاحظ أن كل شخص يمكن أن يظهر في جدول المستخدمين مرة واحدة فقط› 
لأن جدول المستخدمين هو في الحقيقة امتداد لجدول الشخص في حالة إذا كان 
موظفا في الشركة ويتاح له استخدام البرنامج.. لهذا تسمى هذه العلاقة علاقة 
واحد بواحد 0-018)-ع01» على عكس علاقة جدول الشخص بجدول 
الهواتف» فهي علاقة واحد بمتعدد yدةN-٥1-ع01»‏ لأن الشخص الواحد 
يمكن أن تكون له هو اتف متعددة. 

وفي الوضع الافتراضي يكون الارتباط الذي ننشئه من النو ع 2y‏ M-0)-ع”0»ء‏ 
ولتغير هذا في الارتباط بين فئة الشخص وفئة المستخدم» اضغط السهم الممشل 
للارتباط بزر الفأرة الأيمن» ومن القائمة الموضعية اضغط ع٤٥‏ 0pإP..‏ 
ستجد خاصيتين هامتين في نافذة الخصائص عليك تغيير قيمتيهماء كما هو 


موضح في الجدول: 
الخاصية القيمة ملاحظات 
الأصل 07۴100”١‏ تحدد نوع العلاقة.. نريد هنا علاقة واحد 
Cardinality‏ وا 
متفرد 6 _ تجعل المفتاح الفرعي متفرداء لكي لا 
Unique‏ يظهر نفس رقم الشخص أكثر من مرة مع 


لاحظ أن إنشاء علاقة من النوع واحد بواحد» يجعل الخاصية التي تضاف إلى 
الفئة الرئيسية مفردة الاسم.. أي أن الفثة ۴٠۲50١‏ ستحتوي على خاصية اسمها 
۲ل تعيد المستخدم الموجود على الطرف الآخر من العلاقةء كما أن الففة 
٣‏ ستحتوي على خاصیة اسمها ۸١۲0ء۴‏ تعيد الشخص الموجود على 
الطرف الآخر من العلاقة.. والأفضل أن تتأكد أن اسم كل من خاصيتي الربط 
مفرد» وذلك باستخدام الخاصيتjı Child Property ş Parent Property‏ من 
نافذة الخصائص» حيث ستجد العلامة + بجوار كل منهماء وعند ضغطها سيتم 
إسدال بعض الخصائص الفرعية» وستجد من بينها الخاصية مصه".. تأكد أن 
هذه الخاصية تحتوي على القیمتین ۲٥۲۹0۸‏ و ٥۲‏ ءل على الترتیب. 

والجدول التالي يصف لك الخصائص الأخرى التي يجب أن تضيفها إلى الففة 


;: User 
Nullable Type Source الخاصية‎ 
False String ٠ UserName UserName 
False String Password | Password 
False Boolean  IsAmdin | IsAmdin 
False Boolean Enabled Enabled 


لاحظ أن كل مستخدم سيكون له اسم مستخدم وكلمة مرور ليستخدمهما لتسجيل 
دخوله إلى البرنامج.. أما الخاصية «ال٣ص4ء[‏ فهي خاصية منطقية 2ء001 8› 
لو وضعنا فيها 1۲٠٠‏ فسيدل هذا على أن هذا المستخدم أحد مديري النظام» وله 
صلاحية إضافة وحذف المستخدمين.. أما لو وضعنا فيها ١۴ء‏ فسيعني هذا 


۲٣ 


أنه مستخدم عادي يحق له استخدام البرنامج دون أن يستطيع إضافة أو حذف 
أما الخاصية 4٥1ط8.2‏ فهي تتيح للمدير تعطيل أو تفعيل المستخدم.. فلو وضع 
فيها المدير القيمة 1٠٠‏ فهذا يعني أن المستخدم فعال ويمكنه استخدام 


البرنامج.. أما لو وضع فيها ٥ء۴41‏ فهذا يعني أن المستخدم معطل ولا يستطيع 
استخدام البرنامج.. الحكمة من وراء هذاء هي أن نتحاشى حذف المستخدمين 
من قاعدة البيانات» لأن حذف المستخدم سيجبرنا على حذف كل مواعيده 
الموجودة في جدول المواعيد وكذلك حذف بياناته الموجودة في جدول 
الموظفين.. بينما من الذكاء أن نترك كل البيانات القديمة موجودة كنوع من 
البرنامج.. لهذا سنستخدم خاصية التعطيل بدلا من الحذف. 

أخيرا: أنشئ ارتباطا ڊjı Person .ID‏ ڪ User.PersonID‏ „, 


لاحظ أن جدول المواعيد ناقص» فنحن لا نعرف المستخدم الذي سيكون معه 
الموعد.. لهذا توجه إلى الفئة ع«ناء× وأضف إليها خاصية جديدة اسمها 
0D‏ لتعمل كمفتاح فرعي .. استخدم الخاصية $0۲١١‏ لتجعل مصدرها 
العمود ۲12ءءلا؛ء واستخدم الخاصية عمرآ لتجعل نوعها إ#عمام[ء ثم أنشئ 
ارتباطا بينها وبين الحقل 10 في الفئة امهل , 


۷ 


ملحوظة: 

يمكن أن يحتوي الجدول على أكثر من مفتاح فرعي .. لكنه لا يمكن أن 
يحتوي إلا على مفتاح رئيسي واحد. 

ويمكن أن يدخل الجدول في أكثر من علاقة مع عدد من الجداول 
الأخری» سواء تكرر كونه جدولا رئيسيا أو جدولا فرعيا. 

مثلا: الفئة ۶٥۲0١‏ هي الفئة الرئيسية في كل علاقاتما مع الففغات 
الأخرى.. والفئة ع«ناعع" هي الفئة الفرعية في العلاقتين اللتين دخلت 


يجب أن يبدو المخطط النهائي لمحتوى البيانات كالتالي: 


Hetimg EE 
= Frappr DE = Proper EE 
r ım 1F Dp 
3F PersonIDı TT Perrin 
T Time T Pere 
3 Girailorn 3 Lapin 
TT Place ا‎ 
TT feason 
FT Rete: 
7 e 


TF Ip CEND 


۲۸ 


التحكم في طول الحقول النصية: 

في كل الحقول النصية التي أنشأناها في الفئات» لم نحدد أقصى طول مسموح 
به لكل حقل.. هذا يجعل سيكويل سيرفر يفترض أقصى طول ممكن للحقل.. 
هذا الطول يكون ٠٠٠٠١‏ حرف إذا كان النص يستخدم الترميز العالمي الموسع 
ئا كما في حالة التعامل مع اللغة العربية.. طبعا هذا رقم كبير بالنسبة 
لاحتياجناء وعلينا أن نغيره.. لفعل هذاء يمكننا أن نحدد النوع الحقيقي للحقل من 
بين الأنواع التي تتعامل معها قاعدة البيانات.. بالنسبة للنصوص» سنستخدم 
الن و ع »۷a]c۸2۲)(‏ حیث: 


الحرف ١‏ في الاسم يعني أن النص يستخدم الترميز الموسع.. نحن 
نحتاج إلى هذا لكي يمكننا حفظ الحروف العربية.. لو استخدمت النوع 
(12۲)1ءvar‏ فستتحول كل الحروف العربية إلى علامات استفهام 
وستفقد النص الأصلي . 

الحروف ۷4١‏ هي اختصار الكلمة ۷4۲1۵١٤‏ بمعنى متنوع.. هذا معناه أن 
النص قد يطول أو يقصر» وسيتم حفظه كما هو بدون إكمال النص 
القصير بوضع مسافات.. لو استخدمت النوع 11ء فسيتم إكمال النص 
القصير بوضع مسافات» ليكون لجميع النصوص نفس الطول. 

الحروف ١12۲ء‏ هي اختصار الكلمة ١12۲2٥٥۲‏ بمعنى حرف . 

الحرف 1 بين القوسين يمتل الحد الأقصى لعدد حروف النص.. مثلا:؛ 
(12۲)30ءإ۷a"‏ يعني أن أقصى نص سيقبله الحقل هو ٠١٠‏ حرفا. 


ولكي نحدد نوع البيانات الخاص بسيكويل سيرفرء يمكننا استخدام الخاصية 
Server Data "ype‏ من نافذة الخصائص.. مثلا: عليك أن تضع النص 


۲۹ 


(archa2)30رn‏ في الخاصية ءمyp‏ 1 Server (ata‏ التاإبعة للحقل 
»۴erson. Nane‏ لكي تحدد أقصى طول لاسم الشخص بثلاثين حرفا. 
استخدم الجدول التالي لتعديل قيم هذه الخاصية في كل الحقول النصية: 


Server Data Type الحقل‎ 
nvarchar(30) Person.Name 
nvarchar(500) Person.Address 
nvarchar(50) Person.Company 
nvarchar(20) Person.Job 
nvarchar(500) Person.Notes 
nvarchar15) Phone.Phone 
nvarchar(20) Phone.Description 
nvarchar(500) Meeting.Place 
nvarchar(500) Meeting.Reason 
nvarchar(500) Meeting.Notes 
nvarchar(10) User. UserName 
nvarchar(10) User.Password 
nvarchar(10) Importance.Description 


إنشاء قاعدة البيانات: 
يمكننا أن نطلب من محتوى البيانات» أن يقوم بإنشاء قاعدة البيانات بناء على 
مخطط الفئات التي أنشأناها.. لكي نفعل هذا يجب أن نضبط خصائص محتوى 
البيانات أولا. 

اضغط بزر الفأرة الأيمن في أي موضع في مصمم الكائنات يخلو من الففات»› 
ومن القائمة الموضعية اضغط الأمر ٠۲٤1٥١‏ م٠۴۲‏ لفتح نافذة الخصائص . 


۰ 


ستجد في الخاصية Ia ..SmartNoteBookDBDataContext pull Name‏ 
اسم طویل جداء لهذا غیرە إلى 00)58 ..Smar۲Note8‏ لاحظ اننا سنستخدم 
هذا الاسم في كتابة الكودء كما أنه سيكون اسم قاعدة البيانات التي سيتم 
إنشاؤها. 

هناك أيضا خاصية اسمها عacمsعمصNam‏ اxtعont..‏ هذه الخاصة تحدد نطاق 
الاسم الذي سيوضع داخله محتوى البيانات.. ضع في هذه الخاصية الاسم 58. 
بالمثل» هناك خاصية اسمها عacمsعمصNa Entity‏ تحدد نطاق الاسم الذي 
توضع فيه الفئات التي عرفناها في مصمم الكائنات.. ضع فيها أيضا الاسم 
.DB‏ 

أخيراء هناك خاصية اسمها ١10ا‏ ٥ع١١٥)»‏ وهي تحدد طريقة الاتصال بخادم 
سيكويل الذي ستعمل عليه قاعدة البيانات.. اضغط زر الإسدال الموجود في 
كان اق ر أختر :تتن ع لاء اتال حك ستظهن لك اافةة 
الموضحة في الصورة: 


۲۳١ 


Add Connection اة‎ 


Enter information to cannect to the selected data source or click 
"Lhange" to choose a different data source andor provider, 


Data source! 


[icrosoft SAL Server faqllient} Lhange... 1 


Server name: 
eftes 
\SALEXPRESS Refresh 


Lag an ko tha sErYEF 


f Use Windows Authentication 
i Use SAL Server authentication 


USEF Mame! 1 
PASSO; | 


FW Save my password 


Lonnect to a database 


f Select or enter a database name: 
| 2 
{* Attach a database file: 


|ciieooks.mdf BFOWSE,,, | 


Logical name: 


سم 


Advanced... | 
Test Lonnectian 1 Lancel 1 
ر‎ 


في الخانة م4۳[ 86۲۷۴١‏ اكتب اسم خادم سيكويل الذي ستنشئ عليه قاعدة 
البيانات.. هذا الخادم يمكن أن يكون: 
- خادما حقيقيا سواء كان يعمل على شبكة kإم‏ سام" أو يعمل عن بعد 
Remote Server‏ وفي هذه الحالة يجب أن تكتب عنوان الإنترنت 
الخاص به مثل 191.0.0.2.. هذا العنوان تحصل عليه من مدير النظام 
المسئول عن هذا الخادم. 


۲۲ 


وفي الغالب سيكون هناك اسم مستخدم وكلمة سر» وعليك أن تختار 
استخدام تحقيق هوية سیکویل سیرفر Use SQL Server‏ 
Authentication‏ لک تکتبهما في الخانتین Use Nam‏ و 
Password‏ . 

خادم محلي 10٥41 5٥۲۷٥۵۲‏ يعمل على جهاز المستخدم.. هذا يسمح لك 
بتشغيل قاعدة البيانات على نفس الجهاز الذي يعمل عليه البرنامج» وهذا 
معناه أنها ستكون خاصة بمستخدم واحد فقط.. هذا يحدث أثاء تصميمك 
للبرنامج لكي يمكنك تجربته على قاعدة بيانات محلية موجودة على 
جهازك دون أن تفسد قاعدة البيانات الرئيسيةء ويمكن أن يحدث أيضا إذا 
كنت تريد أن يكون لكل مستخدم قاعدة بيانات مستقلة خاصة به موجودة 
على جهازه. 

ولكي تتعامل مع الخادم المحلي» اكتب الاسم ككع]م×ء|٩ءا.‏ في الخانة 
Nae‏ ۲عvاSe..‏ هذا هو اسم الخادم المحلي الخاص بسيكويل سيرفر 
۸.. لاحظ أن النقطة في بداية الاسم هي اختصار يرمز إلى اسم 
جهازك» لأن كل جهاز يعتبر خادما محليا.. لكن نظرا لأن اسم الجهاز 
سيختلف من مستخدم إلى آخر» تم الاتفاق على أن يرمز له بالنقطة أو 
بالكلمة )10٥41(‏ ويجب أن تضع القوسين حولها. 

في هذه الحالة لا تحتاج إلى اسم مستخدم وكلمة سر لهذا اختر تحقيق 


, Use Windows Authenticat10¬ زjوgدiيgll هوي‎ 


i 


اضغط الزر ١10)ءم«صصم٣€‏ 1ء٥1‏ .. إذا كان الخادم يعمل وكتبت اسمه بشكل 
صحيح» فستظهر رسالة تخبرك أن كل شيء على ما يرام.. اضغط 0K‏ 
لإغلاق النافذة. 
الآن يمكننا إنشاء قاعدة البيانات.. اضغط K1۸1+S‏ لحفظ التغييرات التي 
أجریناها على محتوی البیانات» ثم انتقل إلى النموذج ۴٥۲۳1‏ وضع عليه زرا 
اسمه ا(عا2ءا٣B)n‏ وضع عليه العنوان "إنشاء قاعدة البيانات".. اكتب في 
حدث ضغط هذا الزر الكود التالي: 
Try‏ 
Dim SnbDB As New DB.SmartNoteBookDB‏ 
If Not SnbDB.DatabaseExists Then‏ 
SnbDB.CreateDatabase( )‏ 
End If‏ 
Catch Ex as Exception‏ 


MsgBox(Ex.Message) 
End Try 


في بداية هذا الكود» عرفنا متغيرا من نوع محتوى البيانات» لكي يمكننا من 
خلاله إنشاء قاعدة البيانات.. لاحظ أننا كتبنا اسم محتوى البيانات منسوبا إلى 
النطاق 08 الذي عرّفناه باستخدام نافذة الخصائص . 

وقد استخدمنا وسيلة اسمها ءائا×٤عءةطاه)ه(»‏ وهي تعید عں٣ا‏ إِذا كانت 
قاعدة البيانات موجودة بالفعل على سيكويل سيرفر.. طبعا لن نحاول إنشاء 
قاعدة البيانات إذا كانت موجودة» حتى لا يحدث خطاً. 

بعد هذا استخدمنا الوسيلة عووطه)ة(ع)هع]C‏ لإنشاء قاعدة البيانات. 

لاحظ أن خطأً سيحدث إذا كنت نسيت وضع اسم المصدر 801۲٠١‏ في أي فئة 
أو خاصية في محتوى البيانات (ولهذا استخدمنا مقطع معالجة الأخطاء).. في 


۳٤ 


هذه الحالة سيتم إنشاء قاعدة البيانات»ء لكن لن يتم إنشاء الجدول الذي فيه 
المشكلة.. لهذا ربما تريد حذف قاعدة البيانات» لكي تصلح المشكلةء ثم تعيد 
عنوانه "حذف قاعدة البيانات"» واكتب ما يلي في حدث ضغطه: 
Try‏ 
Dim SnbDB As New DB.SmartNoteBookDB‏ 
SnbDB.DeleteDatabase( )‏ 
Catch Ex As Exception‏ 


MsgBox(Ex.Message) 
End Try 


هذا الكود يعرف متغيرا من فئة محتوى البيانات» ثم يستخدم الوسيلة 
eteDatabaseاe(‏ لحذف قاعدة البيانات . 
والآنء شغل البرنامج» واضغط الزر "إنشاء قاعدة البيانات".. إذا لم يحدث أي 
خطأء فهذا معناه أن قاعدة البيانات قد تم إنشاؤها بنجاح.. في هذه الحالة سيتم 
اقتاد فی خان ا اة 
MSSQL10.SQLEXPRESS\ MSSQL\DATA‏ 
على المسار الخاص ببرنامج سيكويل سيرفر» وهو في الغالب: 
C:\Program Files\Microsoft SQL Server\‏ 
هذان الملفان هما: 
- artlNoteBookDB.mdfےSm:‏ هذا هو ملف قاعدة البیانات . 
- og.LDFا_SmartNoteBookDB:‏ هذا ھو ملف سجل آحداث قاعدة 
البيانات. 
ولا تعمل قاعدة البيانات بدون وجود هذين الملفين معا. 


ويمكنك نشخ الملفين ووضتخهما في أي مجلد آخر.خاأض بك كسخة احتياطية 
فارغة. 
أخيراء يجب علينا أن نجعل محتوى البيانات يتصل بقاعدة البيانات التي 
أنشأناها.. لاحظ أننا جعلناه يتصل بالخادم فقطء دون تحديد قاعدة بيانات.. نريد 
الآن أن نجعله يتصل بقاعدة البيانات» لكي يربط الجداول بالفئات التي أنشأناهاء 
مما يمكننا من قراءة البيانات وحفظها في قاعدة البيانات من خلال محتوى 
البيانات . 
لفعل هذا انقر العنصر 1صإطd. k(8‏ BءSmariNot‏ مرتين في متصفح 
المشاريع لعرض مصمم الكائنات» واعرض خصائص محتوى البيانات.. اضغط 
الزر الموجود في خانة الخاصية ١0ناءم«صه‏ واختر الأمر »)Ne(‏ وفي 
نافذة إنشاء اتصال اكتب اسم الخادم كوءإم×5418|..» وفي الجزء السفلي من 
النافذة فعل الاختيار: 

Select or enter database name 
واضغط زر الإسدال الموجود في الخانة الموجودة أسفله.. ستمر لحظات قبل أن‎ 
تظهر قائمة فيها أسماء قواعد البيانات التي تعمل على الخادم المحلي.. اختر‎ 
OK biضl,‎ SmartNoteBookDB :lنiڊ منها قاعدة البيانات الخاصة‎ 
لإغلاق النافذة.‎ 
إنشاء مدير افتراضي للبرنامج:‎ 
يجب أن يكون هناك مدير واحد على الأقل في هذا البرنامج» لكي يمكنه إنشاء‎ 


مستخدمين آخرين للبرنامج.. لهذا يجب علينا أن نضيف مديرا افتراضياء ونحدد 


۲۳٢ 


له اسم مستخدم (ولیکن نص ل4) وكلمة سر (ولتكن ما0,٤14۲ء)‏ بحيث نعطي 

هذه المعلومة للمدير الذي سيستخدم البرنامج» ليمكنه تشغيله في أول مرة» وبعد 

هذا يستطيع تغيير اسم المستخدم وكلمة السر الخاصين به كما يشاء. 

ضف زرا جدیدا على النموذج ۴٥۲۳1‏ اسمه ٣ہ 8Bi, 44d‏ واکتب ما 
ا Dim SnbDB As New DB.SmartNoteBookDB‏ 


Dim Admins = From user In SnbDb.Users 
Where user.IsAdmin 


If Admins.Count = 0 Then 
Dim Pr As New DB.Person With {.Name = "Admin''} 
Dim Admin As New DB.User With { 
.IsAdmin = True, .Enabled = True, 
. UserName = "Admin'", .'Password = ''smartnote'", 
.Person = Pr} 


SnbDB.Users.InsertOnSubmit(A dmin) 
SnbDB.SubmitChanges( ) 
End If 


دعنا نفهم هذا الكود: 

في البداية عرّفنا متغيرا اسمه 5۸,528 لنتعامل من خلاله مع محتوى 
البيانات.. لاحظ أن محتوى البيانات يعرف خاصية باسم كل جدول في قاعدة 
البيانات.. هذا معناه أن محتوى البيانات الخاص بنا يحتوي على الخصائص 
الموضحة في الجدول: 


۳۷ 


الخاصية وظيفتها 
Persons‏ تعید جدو لا صفوفه من نوع الفئة 0۲ء۲٥‏ ۴.. أي أن هذه 
الخاصية من النو ع .Table)0Of Per07(‏ 
5( ||تعيد جدولا صفوفه من نوع الفئة إمءلا.. أي أن هذه 
الخاصية من النو ع (إse‏ ل 0۴)ء]ab.‏ 
Phones‏ تعيد جدولا صفوفه من نوع الفئة ٠١0ط۴..‏ أي أن هذه 
الخاصية من gill‏ ع .Table(Of Phone)‏ 
Meetings‏ تعید جدو لا صفوفه من نوع الفغة ع«ناء×.. أي أن 
هذه الخاصية من gill‏ ع .Table(Of Meeting)‏ 
Importances‏ تعید جدولا صفوفه من نوع الفغة 0)4٤‏ مpصآ..‏ آي 
أن هذه الخاصية من gill‏ ع .Table(Of Importance)‏ 


ويتحكم محتوى البيانات في كيفية ملء هذه الجداول بالصفوف من قاعدة 
البيانات بأفضل كفاءة وسرعة»ء دون أن نشغل أنفسنا بتفاصيل هذا. 


الكينونة رازہ :E‏ 


هي نسخة ce‏ nهھtیم[‏ (أو كائن tءەزطا0)‏ من إحدى فات محتوى 


۳۸ 


ويمكنك التعامل مع كل خانة في الكينونةء من خلال الخصائص التي عرفناها 
في كل فئة.. فمثلا: يمكن عرض اسم أول شخص في جدول الأشخاص بالجملة 
التالية: 
MsgBox(SnbDB.Persons(0).Name)‏ 

والمريح في الأمرء هو أننا نستطيع استخدام استعلامات 111Q‏ للحصول على 
البيانات التي نريدها من كل جدول من جداول محتوى البيانات.. وقد استخدمنا 
استعلاما بسيطا يعيد المستخدمين الذين لهم صلاحيات المديرء وذلك بالتأكد من 
أن الخاصية 144۳1١‏ الخاصة بهم تحتوي على القيمة عل1۲.. بعد هذا 
سنفحص عدد نتائج هذا الاستعلام» فإن كانت صفرا (أي لا يوجد مديرون)ء 
فسنضيف مديرا افتراضيا إلى الجدول. 
لاحظ أننا نستطيع تحسين الاستعلام السابق»ء فكل ما أردناه منه هو حساب عدد 
المديرين» فلماذا نرهق قاعدة البيانات بإرسال كل بيانات المديرين إلينا؟.. تذكر 
دائما أن قاعدة البيانات قد توجد على خادم 56۲۷۴6۲» وأن هذا الخادم عليه 
ضغوط كثيرة من مستخدمين كثيرين» وأن البيانات التي تطلبها تصل إليك عبر 
شبكة اتصال» مما يعني أن عملية النقل قد تكون بطيئةء وتزداد بطئا كلما زاد 
حجم البيانات التي تطلبها.. لكل هذا عليك ألا تطلب من الخادم أية بيانات لا 
تحتاجهاء وأن تكتب أكفأً استعلام يجعلك تؤدي وظيفة برنامجك في أسرع وقت. 
إذن» فالأفضل أن نعيد كتابة الاستعلام السابق ليصير كالتالي: 

Dim AdminsCount = Aggregate User In SnbDB.Users 

Into Count(User.IsAdmin) 


هذا الاستعلام يسمى استعلام التجميع رإعاQ‏ ع2ع٠إععA,‏ وهو يبدا بالكلمة 
ggregate‏ بدلا من الكلمة ۴۲٥۳‏ ويستخدم الكلمة 1"0 بدلا من الكلمة 


۲۹ 


tعاSe»‏ وتتبع الكلمة [٣٥‏ إحدى دوال إلتجınعg «Min «Max «Count)‏ 
Avg Sum‏ ... إلخ). 
ولدالة التجميع ٣011۲‏ صيغتان : 
- الصيغة الأولى لا تستقبل أي معاملات» وهي تعيد عدد الصفوف الموجودة 
في الجدول الذي نستعلم عنه. 
- والصيغة الثانية تستقبل شرطاء لتعيد عدد صفوف الجدول التي تحقق هذا 
الشرط.. وقد استخدمنا هنا llلشفرhط User.IsAdmin = True‏ 
(وكاختصار لم نكتب الجزء ع1۲ =) لنحصل على عدد الصفوف التي 
تحتوي الخانة ٣۳٣1١‏ ۸] فيھا على القيمة عuإآ1.‏ 
لاحظ أن القيمة العائدة من استعلام التجميع تكون عددا صحيحا وليس مجموعة 
نتائج.. لهذا سیکون المتغیر 011٣٤١ص‏ ك۸ من النوع ١ءعع)م[ء‏ ويمكننا 
استخدامه فى جملة الشرط مباشرة كالتالى : 
If AdminsCount = 0 Then‏ 
نفس الكود السابق ' 
End If‏ 
نرید الان ان نفهم الكود الذي استخدمناه لإضافة مدير دا کت ٠‏ 
نتفق على أن أي مستخدم يجب أن يكون شخصاء لأن جدول المستخدمين تابع 
لجدول الأشخاص.. لهذا يجب أن نضيف شخصا إلى جدول الأشخاص أولا 
وليكن اسمه ”طك۸ دون الاهتمام بباقي بياناته» حتى يمكننا أن نجعل هذا 
الشخص مستخدما في جدول المستخدمين . 


لفعل هذا عرفنا كينونة جديدة من فئة الشخص» بنفس الطريقة التي نعرف بها 
متغيرا من أي فئةء ووضعنا في الخاصية ۳٥‏ لهذا الشخص الجديد القيمة 
:Admin‏ 
Dim Pr As New DB.Person With {.Name = '"'"Admin'"'}‏ 
وبالمثل» عرأفنا كينونة جديدة من فئة المستخدم» وجعانا هذا المستخدم مديرا 
بوضع القيمة 1۲٠٥١‏ في الخاصية [۸1۳1١‏ وجعلناه مستخدما فعالا بوضع 
القيمة ع1۲ في الخاصية dء1طا8"2›‏ مع تحديد اسم مستخدم وكلمة سر 
افتراضيين وليكونا (نصط ك۸ و ما0٣ا۲ةء)..‏ أخيراء لكي نربط هذا 
المستخدم بالشخص الذي يمثله» وضعنا كينونة الشخص في الخاصية ۲0۸ء۴٣‏ 
التي تربط بين الفئتين: 
Dim Admin As New DB.User With {‏ 
.IsSAdmin = True, .Enabled = True,‏ 
UserName = "Admin'"",‏ . 


.Password = ''smartnote'"", 
.Person = Pr} 


لاحظ أننالم نهتم بوضع قيم الخصائص s01.10إPe‏ ڇڪ User.ID‏ 
و n1Dص0ءاء۴ se.‏ فرقم الشخص ورقم المستخدم سيولدان تلقائيا عند إضافة 
سجل الشخص وسجل المستخدم إلى قاعدة البيانات» والعلاقة بينهما ستجعل 
الخاصية 12,هءإء۴.إءء0 تأخذ نفس الرقم الذي سيوضع في الخاصية 
0D‏ وذلك لأننا جعلنا المستخدم الجديد يرتبط بالشخص الجديد 
.(.Person = Pr)‏ 

لاحظ أن كل ما فعلناه حتى الآن لا يؤّثر على جداول محتوى البيانات.. فقد 
عرفنا كينونتين مستقلتين ولم نضفهما بعد إلى أية جداول. 


٤١ 


لإضافة كينونة إلى أي جدول» يمكنك استخدام InsertOnSubmit lll‏ 
الخاصة بهذا الجدول» ومعناها "الإدراج عند الإرسال".. هذا يعني أن هذه 
الوسيلة لن تضيف الكينونة إلى الجدول إلا بعد إرسال التغييرات من محتوى 
البيانات إلى قاعدة البيانات» وهو مايمكن فعله باستخدام الوسيلة 
:SubmitChanges‏ 


SnbDB.Users.InsertOnSubmit(Admin) 
SnbDB.SubmitChanges( ) 


وتذكر دائما أن أي تغييرات تجريها على جداول محتوى البيانات» لا تؤثر 
مباشرة على قاعدة البيانات» بل تظل محفوظة في محتوى البيانات في ذاكرة 
جهازك» إلى أن تستدعي الوسيلة sمعرة‏ ا٣٤ص‏ طان؟.. هذه الوسيلة تقوم بما 
يلي: 

١‏ - أي تغيير في بيانات الجداول تحفظه في قاعدة البيانات. 

- أي سجل أضيف إلى الجداول» تضيفه إلى قاعدة البيانات. 

۳ -أي سجل حذف من الجداول» تحذفه من قاعدة البيانات. 
لكنٌ هناك سو الا هاما هنا: 
لماذا أدرجنا الكينونة ”نص ك۸ في جدول المستخدمين باستخدام الوسيلة 
num‏ sert0[ء‏ ولم ندر ج كينونة الشخص في جدول الأشخاص بالمثل؟ 
السبب في هذا أننا ربطنا كينونة المستخدم بكينونة الشخص من خلال الخاصية 
ser. P1‏ .. إن محتوی البیانات دكي جدا» وحينما يجد أن المستخدم 
الجديد مرتبط بشخص جديد» فسيضيفهما معا إلى قاعدة البيانات.. لهذا كان 
يمكننا كتابة الكود السابق بالطريقة العكسية» وذلك بإضافة سجل المستخدم إلى 


:InsertOnSubmit 


Dim Admin As New DB.User With { 
.IsSAdmin = True, .Enabled = True, 
. UserName = "Admin'"", 
.Password = '"'smartnote'"'} 

Dim Pr As New DB.Person With { 

.Name = '"Admin'"", .User = Admin} 
SnbDB.Persons.InsertOnSubmit(Pr) 
SnbDB.SubmitChanges( ) 

وفي كلتا الطريقتين سيتم حفظ سجلي الشخص والمستخدم في قاعدة البيانات. 
والآن شغل البرنامج» واضغط زر إضافة المديرء ثم أغلقه. 


إضافة درجات الأهمية إلى قاعدة البيانات: 
ضع زرا على النموذج ۴0۲11 عنوانه "إضافة درجات الأهمية"» واكتب الكود 
التالي في حدث ضغطه: 
Dim SnbDB As New DB.SmartNoteBookDB‏ 
Dim ImpCount = Aggregate Imp In SnbDB.Importances‏ 
Into Count( )‏ 


If ImpCount = 0 Then 
Dim Imp As New DB.Importance With { 


.ID = 0, .Description = ''يدlع''}‎ 


SnbDB.Importances.InsertOnSubmit(I[Imp) 
Imp = New DB.Importance With { 


.ID =1, .Description = '""ala''} 
SnbDB.Importances.InsertOnSubmit(I[mp) 


<۳ 


Imp = New DB.Importance With { 
.ID =2, .Description = ''Iدج‎ مlه''}‎ 


SnbDB.Importances.InsertOnSubmit(Imp) 
SnbDB.SubmitChanges( ) 
End If 


هذا الكود واضح» فهو يستعلم عن عدد السجلات في الجدول sعImportanc‏ 
فإن كان صفرا فإنه يضيف تلاثة سجلات جديدة إلى هذا الجدول» بتعريف 
كينونة لكل سجل وإضافتها إلى الجدول عند الإرسال» ثم إرسال التغييرات. 
والآن شغل البرنامج» واضغط زر إضافة درجات الأهميةء ثم أغلقه. 

نحن الآأن جاهزون لتصميم نماذج المشروع. 


ملحوظة: 

لن نعرض النموذج ۴١۲۳٣1‏ لمستخدم البرنامج ولا حتى للمدير.. هذا 
النموذج خاص بنا نحن - المبرمجين - فقد استخدمناه لإنشاء قاعدة 
البيانات ووضع القيم الابتدائية فيها. 


[صدارات م. محمد حمدې غانم 
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انتهاك حدود اللحظة (ديوان شعر) 


- مكتبة دار المعرفة: 
؛ شارع السرايات - أمام هندسة عين شمس - بالقرب من ميدان عبده 
باشا ‏ العباسية ‏ القاهرة. 


- مكتبة الأنجلو : 


ميدان باب اللوق - القاهرة. 


- المكتية الأكاديمبة: 


ov 


أمام مدخل محطة مترو الدقي» شارع التحريرء الجيزة. 


- مكتبة منشأة المعارف ومكتبة علاء الدين: 
محطة الرمل ‏ الإسكندرية. 


= دار المعارف: 


الإسماعيليةء انشوظ, 


- للحصول على الكتب في دمياطء يرجى الاتصال بالأستاذ رجب عبد الواحد 
على الهاتف ۰۱۸٦۷۱٦۷۹۸‏ . 


- للحصول على الكتب في المنصورةء يرجى الاتصال بالأستاذ أحمد غانم على 
الهاتف ۰٠۱۹۱۱۷۳۱۳۷‏ . 


- للحصول على الكتب في المنوفيةء يرجى الاتصال بالأستاذ عماد عبد الحليم 
على الهاتف ۰0۹۷1۷0۹٩‏ , 


- مكتبة العبيكان: 
العمكة المر ية ال دة 


o۸ 


- مكتبة الهندسة: 
جازان الففكة العرية اة 


للاستعلام عن أماكن بيع الكتب في باقي المحافظات المصريةء يمكن الاتصال 
بمكتبة دار المعرفة على الهاتف ٠۲/۲٠۸٤٤١٤١‏ أو عبر البريد الإلكتروني: 
dar_elmaarefa @yahoo.com‏ 


للراغبين في إرسال كتبي إليهم خارج مصر عبر البريد: 

تكلفة الشحن عبر البريد هي : 

٠‏ جنيه (تكاليف ثابتة على الطرد) + ٠١‏ جنيه على كل كيلو جرام من وزن 
الطرد. 

بالنسبة لكتبي الكبيرة ۷٠١(‏ و٠٠۸‏ صفحة)»ء فمتوسط وزنها حوالي كجم» أي 
أن إرسال نسخة من أي كتاب منها سيتكلف ٠١‏ جنيهات مقابل الوزن إضافة 
إلى ٠٠‏ جنيه مصاريف الطرد.. أي أن تكلفة الشحن ستكون ۷۰١‏ جنيها مصريا 
+ سعر الكتاب ۷٠١‏ جنيهاء أي أن التكلفة الإجمالية ستكون حوالي ٠٤٠١‏ جنيها 
مصرياء أي حوالي ۲١‏ دولارا. 

بالنسبة لكتاب إطار العمل وكتاب المدخل العمل السريع فكل منهما نصف الوزن 
ونصف السعر» أي أن طلب نسختين منهما عبر البريد سيتكلف ۲١‏ دولارا. 
أما الكتابان الصغيران (المبرمج الصغير والانتقال من فيجيوال بيزيك إلى سي 
شارب)» فهما ربع الوزن وربع السعر»ء أي أن ٤‏ نسخ من أي منهما ستتكلف 
٥‏ دولارا. 


°۹ 


ملحوظة هامة: 

كلما زاد عدد نسخ الكتب في الطرد الواحد» قلت التكلفة الإضافية المضافة على 
سعر كل كتاب» نتيجة لتوزيع تكلفة الشحن على أكثر من كتاب.. كما أن طلب 
عدد من الكتب يجعل المكتبة تمنحك نسبة خصح» وكلما زاد عدد النسخ تزيد 
نسبة الخصم.. إن خصما نسبته %٠١‏ مثلا على ٠١‏ نسخ من الكتب كبيرة 
الحجم سيغطي تقريبا تكاليف الشحن.. لهذا سيكون من الأفضل لو اشترك 
مجموعة من الأصدقاء في طلب مجموعة من الكتب معا كي لا يتحملوا أي 
تكاليف إضافية على أسعار هذه الكتب. 


على الراغبين في الحصول على الكتب بهذه الطريقةء الاتصال بالأستاذ عماد 
عبد الحليم المسئول في مكتبة دار المعرفة على هاتفه 20107675099+ أو 
إرسال رسالة $۷18 مختصرة إليه» بشرط أن يذكر فيها عدد النسخ المطلوبة 
من كل كتاب» واسم البلد المراد الإرسال إليهء والعنوان» ليحسب تكاليف 
الشحن» ويخبركم بكيفية التحويل. 
مثلاء هذا نص رسالة مقترح: 
آريد ۳ نسخ من كتاب برمجة الويندوز (بيزيك)» ونسختين من كتاب قواعد 
البيانات (سي شارب).. 
عنوان الشحن: mm‏ 
البلد: mnn‏ 


وسيرد هو برسالة يوضح فيها سعر الشحن» وكيفية تحويله» وعند تلقي النقود 
سيرسل الكتب على عنوان الشحن الموضح في الرسالة. 
أو يمكنكم مراسلته عبر بريد المكتبة: 

dar_elmaarefa @yahoo.com 
؟SM8 مع ملاحظة أن رده على البريد متقطع وعلى فترات متباعدة.. رسائل‎ 
أسرع وأرخص من مكالمات الهاتف» وستحل مشكلة اختلاف اللهجات.‎ 
وأعتذر مرة أخرى على المشقة.. لكن ما باليد حيلة.‎ 


E 


